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Hossein D. Akhond, et al. 
Serial No. Unknown 
Filed: Unknown 

For: METHOD AND APPARATUS 
FOR RELAYING EVENTS 
INTENDED FOR A FIRST 
APPLICATION PROGRAM TO 
A SECOND APPLICATION 
PROGRAM 

PRELIMINARY AMENDMENT 

Assistant Commissioner for Patents 
Washington, D.C. 20231 

Prior to the examination of the above reference application, the Applicant respectfully 
request the Examiner to enter the following amendments and to consider the following 
remarks. 

In the Specification 

Please add the following after the title: 

RELATED APPLICATIONS 



Examiner: Unknown 
Art Unit: Unknown 



This application is a continuation of U.S. Patent application serial number 08/613,186 
filed on March 8, 1996. 



In the Claims 

Please amend the claims as follows: 



1 1. [Once Amended] A computer-related method for processing, with a preferred processing 

2 application program having a preferred identifier, an event associated with an object 

3 generated by a dedicated creator application program [said dedicated creator application] 

4 having a dedicated identifier, [said] the method comprising [the following steps]: 

5 causing a relay application program to assume the dedicated identifier; 

6 [a. receiving the event;] 

7 [b.] intercepting the event with [a] said relay application program; and 

8 [c] forwarding, with said relay application program, said intercepted event to 

9 [said] the preferred processing application progra m, wherein the event would otherwise be 
10 directed to a dedicated processing application program having the dedicated identifier . 

1 2. [Once Amended] The computer-related method of claim 1 wherein [said step of] 

2 forwarding said intercepted event [includes the steps of] comprises: 

3 identifying the preferred processing application program ; 

4 launching the preferred processing application program ; and 

5 sending [the] said intercepted event to the preferred processing application program. 

1 3. [Once Amended] The computer-related method of claim [2] 1 further [including the 

2 preliminary steps of] comprising: 

3 installing said relay application program; 

4 [associating with said relay application said dedicated identifier;] 

5 installing a selection application program; and 

6 selecting, with said selection application program, the preferred processing 

7 application program. 

1 4. [Once Amended] The computer-related method of claim [3] i wherein an application 

2 program has a creator type and Tsaid] the dedicated identifier corresponds to a first creator 

3 type of [the] said dedicated processing application program. 
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1 5. [Once Amended] The computer-related method of claim 4 wherein [said] the preferred 

2 identifier corresponds to a second creator type of the preferred processing application 

3 program. 

1 6. [Once Amended] The computer-related method of claim 5 wherein installing said relay 

2 application program [is installed according to the following steps,] program comprises: 

3 receiving an install command; 

4 [scanning local drives for all applications having said first creator type;] 

5 changing [the] said creator type for all application^] programs having said first 

6 creator type to a third creator type; 

7 placing said relay application program in condition for launching at a predetermined 

8 time; and 

9 providing user accessibility to said selection application program via a selection 
10 graphic user interface (GUI). 

1 7. [Once Amended] The computer-related method of claim 6 wherein said predetermined 

2 time is [the] a system initialization time. 

1 8. [Once Amended] The computer-related method of claim 6 wherein [said step of] placing 

2 said relay application program in condition for launching [is implemented by] comprises 



3 placing said relay application^] program into [a first location of] a memory. 

1 9. [Once Amended] The computer-related method of claim 6 wherein [said step of] 

2 providing user accessibility to said selection application program via said GUI [is 

3 implemented by] comprises placing said selection application program into a [second 

4 location of said] memory. 



1 10. [Once Amended] The computer-related method of claim [3 wherein said relay 

2 application program is removed according to the following steps,] 8 further comprising; 

3 receiving a remove command; 

4 [scanning local drives for all applications having said second creator type;] 
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5 
6 
7 



changing [the] said creator type of all application^] programs having said [second] 
third creator type to said first creator type; and 

removing said relay application program from [said first location of] said memory. 



1 1 L [Once Amended] A computer system for processing, with a preferred processing module 

2 having a preferred identifier, an event[s] associated with an object generated by a dedicated 

3 creator module having a dedicated identifier, [said events being directed to a dedicated 

4 processing module with a dedicated identifier,] [said] ttie computer system including a 

5 processor, a memory coupled to [said] die processor, an interactive input/output system 

6 coupled to [said] the processor, a display coupled to [said] the processor, [said] the computer 

7 system further comprising: 

8 a module for relaying [said] the event[, associated with an object generated by said 

9 dedicated processing module] to [said] the preferred processing module, said module for 

10 relaying being coupled to [said] the processor and adapted to assume the dedicated identifier 

11 to intercept said event and to forward said intercepted event to the preferred processing 

12 module, wherein the event would otherwise be directed to a dedicated processing application 

13 module having the dedicated identifier ; and 

14 a module for selecting [said] the preferred processing module, said module for 

15 selecting being coupled, at an input thereof^ to [said] the preferred processing module, and at 

16 an output thereof^ to said module for relaying[;]. 

17 [module for installing said module for relaying and said module for selecting, said 

18 module for installing being coupled, at an output thereof to said module for relaying and to 

19 said module for selecting; and] 

20 [module for decoupling said module for relaying and said module for selecting,] 

21 [wherein said module for relaying is adapted to intercept an event associated with an object 

22 generated by said dedicated creator module, said module for relaying being also adapted to 

23 forward said intercepted event to said preferred processing module.] 

1 12. [Unchanged] The computer system of claim 1 1 wherein said module for relaying has an 

2 input for receiving a preferred module identification signal from said module for selecting. 
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1 13. [Once Amended] The computer system of claim 12 wherein said module for relaying has 

2 an output for activating the preferred processing module. 

1 14. [Once Amended] The computer system of claim 13 wherein said module for relaying 

2 [has] comprises a relay processing logic for changing the dedicated identifier of [the] said 

3 intercepted event [with] to the preferred identifier, said relay processing logic being adapted 

4 to send, via [the] said output of [the] said module for relaying, [the] an event with [a] the 

5 preferred identifier to the preferred processing module. 

1 15. [Once Amended] A [computer system for processing, with a preferred processing 

2 application program having a preferred identifier, events associated with objects generated by 

3 a dedicated creator application program, said events being directed to a dedicated processing 

4 application destination with a dedicated identifier, said dedicated creator application program 

5 having a dedicated identifier, said computer system including a processor, a computer- 

6 readable storage medium coupled to said processor, an interactive input/output system 

7 coupled to said processor, a display coupled to said processor, said] computer-readable 

8 storage medium having executable instructions comprising: 

9 [a first region storing] a relay application program for [relaying] intercepting an event 

10 associated with an object generated by [the] a dedicated creator application program and for 

1 1 forwarding said intercepted event to [said] a preferred processing application program,, 

12 wherein the event would otherwise be directed to a dedicated processing application program 

13 having the dedicated identifier ; 

14 [a second region storing] a selection application program for selecting said preferred 

15 processing application program; and 

16 [a third region storing] an installation program for installing said relay application 

17 program and said selection application progra m, said installation program causing said relay 

18 application program to assume a dedicated identifier for said dedicated creator application 

19 program and said dedicated processing application program. T; and] 

20 [a fourth region storing a remover application program for de-installing said relay and 

21 selection application programs;] 
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22 [wherein said relay application program has a first program portion directed to 

23 intercept said event associated with an object generated by said dedicated creator application 

24 program, said relay application program further has a second program portion directed to 

25 forward said intercepted event to said preferred processing application program.] 

1 16. [Once Amended] The compute r-readable medium [system] of claim 15 [wherein said 

2 computer-readable storage medium further includes a fifth region for storing] having further 

3 executable instructions comprising an operating system program[, said operating system 

4 program including a program portion] for activating said relay application program[ stored in 

5 said first region]. 

1 17. [Once Amended] A computer system for processing, with a preferred processing 

2 application program having a preferred identifier, an event[s] associated with an object[s] 

3 generated by a dedicated creator application program, [said dedicated creator application 

4 program] having a dedicated identifier, [said events having a dedicated processing 

5 application destination with a dedicated identifier, said] the computer system including a 

6 processor, a computer-readable storage medium coupled to [said] the processor, an 

7 interactive input/output system coupled to [said] the processor, a display coupled to [said] the 

8 processor, [said computer-readable storage medium] the computer system further comprising: 

9 means for relaying [said] the event[,associated with an object generated by said 

10 dedicated processing application,] to [said] the preferred processing application program , said 

1 1 means for relaying being coupled to [said] the processor and adapted to assume the dedicated 

12 identifier to intercept the event and to forward said intercepted event to the preferred 

13 processing application program, wherein the event would otherwise be directed to a dedicated 

14 processing application program ; and 

15 means for selecting [said] the preferred processing application program, said means 

16 for [relaying] selecting being coupled to [said] the processor!;]. 
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17 [means for installing in said computer system said means for relaying and said means 

18 for selecting, said means for relaying being coupled to said processor;] 

19 [means for de-installing said means for relaying and said means for selection, said 

20 means for relaying being coupled to said processor;] 

21 [wherein said means for relaying is adapted to intercept an event associated with an 

22 object generated by said dedicated processing application program, said means for relaying 

23 being also adapted to forward said event to said preferred processing application program.] 



Please add the following claims: 



1 18. [New] The computer system of claim 11 further comprising: 

2 a module for installing said module for relaying and said module for selecting, said 

3 module for installing being coupled, at an output thereof, to said module for relaying and said 

4 module for selecting. 

1 19. [New] The computer system of claim 1 1 further comprising: 

2 a module for decoupling said module for relaying and said module for selecting. 

1 20. [New] The computer system of claim 1 1 further comprising: 

2 a module for locating copies of the dedicated processing module, said module for 

3 locating being coupled to said module for relaying; and 

4 a module for changing the dedicated identifier of said copies to a different identifier. 

1 21 . [New] The computer readable medium of claim 15 having further executable instructions 

2 comprising: 

3 a remover application program for de-installing said relay and selection application 

4 programs. 

1 22. [New] The computer readable medium of claim 15, wherein said installation program is 

2 adapted to locate copies of said dedicated processing application program and to change the 

3 dedicated identifier for said copies to a different identifier. 
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1 23. [New] The computer system of claim 17 further comprising means for installing said 

2 means for relaying and said means for selecting, said means for installing being coupled to 

3 the processor. 

1 24. [New] The computer system of claim 23 further comprising means for de-installing said 

2 means for relaying and said means for selection, said means for de-installing being coupled to 

3 the processor. 



1 25. [New] A computer readable medium having executable instructions comprising: 

2 causing a relay application to assume a dedicated identifier for a dedicated creator 

3 application and a dedicated processing application; 

4 intercepting, with said relay application, an event associated with an object generated 

5 by said dedicated creator application; and 

6 forwarding, with said relay application, said intercepted event to a preferred 

7 processing application, wherein said event would otherwise be directed to said dedicated 

8 processing application. 

1 26. [New] The computer readable medium of claim 25, wherein forwarding said intercepted 

2 event comprises: 

3 identifying said preferred processing application; 

4 launching said preferred processing application; and 

5 sending said intercepted event to said preferred processing application. 

1 27. [New] The computer readable medium of 25 having further instructions comprising: 

2 installing said relay application; 

3 installing a selection application; and 

4 selecting, with said selection application, said preferred processing application. 

1 28. [New] The computer readable medium of claim 25, wherein an application has a creator 

2 type and said dedicated identifier corresponds to a first creator type. 
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1 29. [New] The computer readable medium of claim 28, wherein said preferred processing 

2 application has a preferred identifier and said preferred identifier corresponds to a second 

3 creator type. 

1 30. [New] The computer readable medium of claim 29, wherein installing said relay 

2 application comprises: 

3 receiving an install command; 

4 changing said creator type for all applications having said first creator type to a third 

5 creator type; 

6 placing said relay application in condition for launching at a predetermined time; and 

7 providing user accessibility to said selection application via a selection graphic user 

8 interface (GUI). 

1 31. [New] The computer readable medium of claim 30, wherein said predetermined time is 

2 a system initialization time. 

1 32. [New] The computer readable medium of claim 30, wherein placing said relay 

2 application in condition for launching comprises placing said relay application into a 

3 memory. 

1 33. [New] The computer readable medium of claim 32 having further instructions 

2 comprising: 

3 receiving a remove command; 

4 changing said creator type for all applications having said third creator type to said 

5 first creator type; and 

6 removing said relay application from said memory.. 

1 34. [New] The computer readable medium of claim 30, wherein providing user accessibility 

2 to said selection application via said GUI comprises placing said selection application into a 

3 memory 
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REMARKS 



The present application is being filed as a continuation of application serial number 
08/613,186, filed March 8, 1996, pursuant to 37 C.F.R. §1.53(b). The Applicant respectfully 
requests consideration of the present application as amended and allowance of pending 
claims 1-34. 
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charges that may be due. Furthermore, if an extension is required, then Applicant hereby 
requests such extension. 
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& ZAFMAN LLP 



Dated: September 29, 2000 



Sheryl S. Holloway 
Attorney for Applicant 
Registration No. 37,850 
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Seventh Floor 

Los Angeles, CA 90025-1026 
(408) 720-3476 



"Express Mail" mailing label number EL627466557US 
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I hereby certify that I am causing this paper or fee to be deposited with the United States Postal Service 
"Express Mail Post Office to Addressee" service under 37 CFR 1.10 on the date indicated above and is 
addressed to the Commissioner of Patents and Trademarks, Washington, D.C. 20231 

Michelle Begay 

(Typed or printed name of persoryrnailing paper or fee) 

(Signature of person nSilmg paper or fee) Date 



10 



Our Ref.: 04860.P1738 



UNITED STATES PATENT APPLICATION 



FOR 



METHOD AND APPARATUS FOR RELAYING EVENTS 
INTENDED FOR A FIRST APPLICATION PROGRAM 
TO A SECOND APPLICATION PROGRAM 



Inventors: Hossein David Akhond 
Gregory George Scown 
Johnathon Paul Kaminar 



Prepared By: 

BLAKELY, SOKOLOFF, TAYLOR & ZAFMAN 
12400 Wilshire Blvd., 7th Floor 
Los Angeles, California 90025-1026 
(310) 207-3800 



I hereby certify that this correspondence is being deposited 
with the United States Postal Service as Express Mail No. 
TB756155708US addressed to: Commissioner of Patents 
and Trademarks, Washington, D.C. 20231, on 

March g. 19% • 

_ mm. 

Carlo Meshach Date 



BACKGROUND OF THE INVENTION 



(1) Field of the Invention 

The present invention relates to the field of computer systems. More 
5 particularly, the present invention pertains to a computer system provided with a 
system for reading files containing data, such as an electronic mail system. 

(2) Description of the Related Art 

As it is well known, most modern computer systems are provided with the 
^ capability of electronically communicating with other computer systems for 
;i0 allowing users to share information. Electronic mail, for example, offers such 
^ capability of communicating by providing the means for transmitting, receiving, 
v5 and processing user-generated messages between computer systems. Electronic 

mail, or e-mail, functions similarly to a post office mail system, by receiving letters 
from a sender and further transmitting these letters to an addressee. Electronic mail 
15 systems also provide features allowing other information to be transmitted from 
one computer system to another, such as files or other data typically referred to as 
enclosures. While typical prior art electronic mail systems have surpassed the 
capabilities offered by conventional post office mail systems, by providing 
capabilities for forwarding mail messages, responding to mail messages, opening 
20 messages, printing messages, removing enclosures (files) included with the 
messages, etc., such electronic mail systems suffer from several disadvantages. 

One disadvantage of prior art electronic mail systems is that they typically 
require the use of a dedicated electronic mail application program for reading and 
otherwise processing messages. For example, in some circumstances the recipient of 
25 a message must read electronic mail documents with the same type of application 
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that the sender used to create the document. Users of computer systems such as, for 
instance, Apple® Computer, Inc., located in Cupertino, California, may prefer to 
read AppleMail™ documents, which are documents created by an AppleMail 
application program (dedicated creator application), with an application program 
5 other than AppleMail. Such a preferred application program may be simply a text 
editor or a more sophisticated program, capable of translating AppleMail 
documents, such as Claris Works or BBedit Similarly, users may desire to open or 
_ print a document created by a first application program (e.g., Microsoft Word) by 
™ : using a second application program (e.g., WordPerfect). 
jfO Conventional computer systems such as Apple systems provide an 

application program such as MacLink® Plus/PC for translating files having a first 
CO format to files having a second format. For example, files having formats 
13 compatible to DOS operating systems can be translated into files compatible with the 
fy Macintosh or Apple operating system. For more information related to the 
[|5 MacLink® translator please see MacLink® Plus PC user manual. Similarly, Apple 
Systems provide an application program called Macintosh Easy Open to simplify 
opening documents created with programs that are not currently installed in the 
system's hard disk. The Easy Open application program recognizes different file 
types and uses built-in translators to help convert files and open them in an 
20 appropriate application that is present in the system. For more information related 
to the Macintosh Easy Open, please see chapter 5 of the publication MACWORLD 
SYSTEM 7.5 BIBLE, 3rd Edition, published by IDG Books Worldwide, Inc. Present 
electronic mail systems, however, do not support the selection of a preferred mail 
reader application different than a dedicated reader application such as AppleMail 
25 reader in Apple systems and redirect an event to such preferred mail reader 
application. 
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In electronic mail, and other application programs which transmit data, the 
sender does not necessarily know the capabilities of the recipient. In the traditional 
post office, all that is required is that the sender knows that the recipient is able to 
read. Similarly electronic mail users should be able to use any type of electronic 
5 mail program, word processing or text editor that they choose, irrespective of that 
used by the sender of the data. This allows users to read and/or process any type of 
mail documents with a preferred application with which they feel more comfortable 
ri or which they find more appropriate for their particular goals. 

£ Figure 1 shows a block diagram of a prior art system with a second application 

program 6 processing an object 2 created by a first application program 1 (e.g. reading 
"J an electronic mail document). The object document 2 can be created by creator 
w application program 1 in a remote computer system or the local computer system. 
u f The object document 2 has a creator type 3 'aaaa' which corresponds to the creator 
a- type 'aaaa' of the creator application program 1. Computer systems such as the 
EL5 Macintosh® of Apple Computer® can identify an application program through the 
"signature" of the application. The signature is a unique four-character sequence 
such as 'aaaa. 1 

Whenever an application program 1 creates a document, the application 
program 1 assigns the document a creator type and a file type. Typically, an 

20 application program sets its signature as the document's creator type 3. When a user 
double-clicks a document or selects it and chooses "Open" or "Print" from the 
Finder's file menu, a Finder 5 reads the creator field 9 of that file to find the 
document's creator type 3. Finder 5 is an application that works with the operating 
system software 4 to keep track of files and to manage the user's desktop display. 

25 After determining the creator type 3, Finder 5 searches for an application program 
with a signature corresponding to the same creator type as the one found in the 
creator field 9 of the object selected or clicked. When Finder 5 finds the application 
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program 6, Finder 5 may launch this application program 6 or call the Process 
Manager to activate the application program. The Process Manager creates a 
partition of memory for the respective application program, loads the code into this 
partition, and performs some operations in preparation for launching. The Process 
5 Manager then returns control to Finder 5. For more information regarding Apple 
systems and identification of applications by signatures see the publication INSIDE 
MACINTOSH, MACINTOSH TOOL BOX ESSENTIALS (1992) available from Addison- 
Wesley Publishing Company. Similarly, conventional mail systems have associated 
§ mail information with an application program that created them by assigning to 
W each mail document a signature or creator type corresponding with the signature of 
C: the creator application program which created that particular mail document. 
W The creator type of the creator application 1 and of the object 2 is used by the 

C Finder 5 to determine what application, in a local system, can process an event 
it- associated with the received object 2. An event is defined as the means by which an 
1.5 Event Manager communicates information about user actions, changes in the 
processing status of the application, and other occurrences that require a response 
from an application. The Event Manager represents the collection of routines that 
an application can use to receive information about actions performed by the user, 
to receive notice of changes in the processing status of the application, and to 
20 communicate with other applications. 

Typically, upon the generation of an event associated with object 2, such as 
double-clicking on a file in the Finder 5, the Finder 5 sends a request to the 
Operating System 4 which, in turn, references a table containing a creator. The table 
is stored in a non-volatile storage media or system memory storing all the 4-byte 
25 creator types or signatures of the applications that are present in the system. For 
each creator type in the table, a dedicated processing application program 6 is 
referenced. For example, when a request or event is sent to open a document that 
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has the creator type 'aaaa,' the Finder will determine whether the 'aaaa' creator type 
is present in that table. Assuming that the creator type is present in the table, the 
Finder then references and alerts the dedicated processing application 6 that a 
request to open a document is pending. For example, assuming that the creator 
5 application 1 is an AppleMail application having the signature 'aaaa/ the source 
object 2 will have the creator type 'aaaa. T Upon receipt of an event associated with 
object 2, such as open document or print document, the Operating System 4 will 
forward the respective event to the dedicated processing application 6 which can be 
ir* an AppleMail application or any application of the same type as the dedicated 
10 creator application program 1. The dedicated processing application 6 will then 
C process the requested event allowing a user, for example, to read the object 2, in the 
fir case where the event associated with the object 2 is an open document event. 
Qj However, according to the system illustrated in Figure 1, the user is typically 

not able to use a preferred local processing application such as e-mail reader or word 
§5 processor, other than the dedicated processing application because the Finder 5 
typically forwards the event associated with object 2 to the dedicated processing 
application 6 or a copy thereof. As such, it is desirable to provide a method and 
apparatus having the capability to forward events associated with an object created 
by a dedicated creator application to a preferred processing application, such that 
20 desired events associated to that object can be processed by the preferred processing 
application program. 
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gRI EF S UMMA RY OF THE INVENTION 



The present invention provides for a computer-related method for 
processing, with a preferred processing application program having a preferred 
5 identifier, an event associated with an object generated by a dedicated creator 
application program having a dedicated identifier. The method includes the 
following steps: a) receiving the event; b) a relay application program intercepting 
the event; and c) the relay application program forwarding the intercepted event to 
± the preferred processing application program. 

10 The present invention also provides for a computer system for processing, 

,t with a preferred processing module having a preferred identifier, events associated 

» with an object generated by a dedicated creator module having a dedicated identifier. 

J; The events directed to the dedicated processing module have a dedicated identifier. 
The computer system includes a processor, a memory coupled to the processor, an 

JS interactive input-output system coupled to the processor, and a display coupled to 
the processor. The computer system further includes: a module for relaying the 
event, associated with an object generated by the dedicated processing application, to 
the preferred processing module, the module for relaying the event being coupled to 
the processor; a module for selecting the preferred processing module, the module 

20 for selecting being coupled at an input thereof to the preferred processing module, 
and that an output thereof to the module for relaying; a module for installing the 
module for relaying and the module for selecting, the module for installing being 
coupled, at an output thereof, to the module for relaying and to the module for 
selecting; and a module for decoupling the module for relaying and the module for 

25 selecting. The module for relaying is adapted to intercept an event associated with 
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an object generated by the dedicated creator module. The module for relaying is also 
adapted to forward the event intercepted to the prefen^d processing module. 



The present invention further includes a computer system for processing, 
with a preferred processing application program having a preferred identifier, 
5 events associated with objects generated by a dedicated creator application program. 
The events are directed to a dedicated processing application destination with a 
dedicated identifier. A dedicated creator application program has a dedicated 
& identifier. The computer system includes a processor, a computer-readable storage 

medium coupled to the processor, an interactive input/output system coupled to 
10 the processor, and a display coupled to the processor. The computer-readable storage 
J; medium includes: a first region storing a relay application program for relaying an 
E event, associated with an object generated by the dedicated creator application 
IE, program, to the preferred processing application program; a second region storing a 
E selection application program for selecting the preferred processing application 
%S program; a third region storing an installation program for installing the relay 
application program and the selection application program; and a fourth region 
storing a removing application program for de-installing the relay and the selection 
application programs. The relay application program has a first program portion 
directed to intercept the event associated with an object generated by the dedicated 
20 creator application program. The relay application program further has a second 
program portion directed to forward the intercepted event to the preferred 
processing application program. 
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RRTFF DESCRIPTION OF T HF. DRAWINGS 



The features, aspects, and advantages of the present invention will become 
more fully apparent from the following Detailed Description, appended claims, and 
5 accompanying drawings in which: 

Figure 1 shows a block diagram of a prior art computer system for processing 
objects with a first creator identifier by an application program having the same 
creator identifier, e.g. reading electronic mail documents; 

Figure 2 shows a block diagram of a computer system on which an 
tlD embodiment of the present invention may be implemented; 

r Figure 3 is a block diagram representing the operation of a computer system 

.£ with an electronic mail system in one implementation of the present invention; 

r Figure 4 is a block diagram illustrating the installation operation of the relay 

U and selection application programs of the computer system in an implementation oi 
15 the present invention; 

Figure 5 illustrates an installation dialog box for the installation of the relay 
application of the computer system in an implementation of the present invention; 

Figure 6 illustrates a process flow diagram of the installation process 
performed by the installer application in the computer system in an 
20 implementation of the present invention; 

Figure 7 shows a high-level flowchart diagram illustrating a process of the 
relay application in an implementation of the present invention; 
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Figure 8 illustrates a more detailed flowchart diagram of the process of the 
relay application; 

Figure 9 illustrates a block diagram of the computer system in an 
implementation of the present invention with the remover application activated; 

Figure 10 shows a flowchart diagram illustrating the process of removal in 
the computer system in an implementation of the present invention; and 

Figure 11 illustrates a memory storing the application programs in an 
implementation of the present invention. 
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DETAILED DESCRIPTION OF THE INVENTION 



In the following description, specific steps, procedures, command options, 
command items, and other specifics are set forth in order to provide a thorough 
5 understanding of the present invention. However, it will be apparent to one skilled 
in the art that the present invention may be practiced without these specific details. 
In other instances, well-known systems and methods are shown in diagrammatic 
block or flow diagram form in order not to unnecessarily obscure the present 
invention. 

16 Referring to Figure 2, a computer system 200, in which an event relaying 

scheme such as the application program of the present invention is incorporated. 
^ The computer system 200 comprises a bus 201 for communicating information and a 
1. processor 202, coupled to bus 201, for processing information. System 200 further 
}r\ comprises a random access memory (RAM) or other dynamic storage device 204 
f| (referred to as main memory), coupled to bus 201, for storing information and 
: C instructions to be executed by processor 202. Main memory 204 may also be used for 
storing temporary variables or other intermediate information during execution of 
instructions by processor 202. Computer system 200 also comprises a read only 
memory (ROM) and/or other static storage device 206 coupled to bus 201 for storing 
20 information and instructions for processor 202, and a mass storage device 207 such 
as a magnetic disk or optical disk and its corresponding disk drive. Mass storage 
device 207 is coupled to bus 201 for storing information and instructions. Computer 
system 200 may further be coupled to a display device 221, such as a cathode ray tube 
(CRT) or liquid crystal display (LCD) via bus 201, for displaying information to a 
25 computer user. Computer system 200 is also coupled to an alphanumeric input 
device 222, including a keyboard, for communicating information and command 
selections to processor 202. Direction information and command selections to 
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processor 202 can be input via a cursor control device 223, such as a mouse, a 
trackball, stylus, or cursor direction keys, coupled to bus 201. Another device which 
may be coupled to bus 201 is hard copy device 224 which may be used for printing 
instructions, data, or other information on a medium such as paper, film, or similar 
5 types of media. While any or all of the components of system 200 and associated 
hardware may be used in a preferred embodiment, it can be appreciated by one 
skilled in the art that any other type of configuration of the system may be used for 
various purposes. 

»i. System 200 may further be coupled to a network interface 225 which provides 

I s ® an interface with a network backbone such as 230. This network 230 may be one of 
C numerous networking systems commercially available, such as the AppleTalk® 
cl brand network available from Apple® Computer, Inc. of Cupertino, California, 

Ethernet, or Token Ring networks as are generally commercially available. Such a 
=!'; network provides an interface among many systems and, therefore, system 200 may 
}S communicate with a second system such as 250, shown in Figure 2, using well- 
known electronic mail techniques for the transmission and reception of electronic 
messages between systems. 

In the preferred embodiment, computer system 200 is one of the Macintosh® 
family of personal computers such as the Macintosh® Quadra™, Macintosh® 
20 Performa™, or PowerMac® brand personal computers manufactured by Apple® 
Computer, Inc. of Cupertino, California (Apple, Macintosh, Quadra, Performa, and 
PowerMac are trademarks of Apple Computer, Inc.). Processor 202 can be one of the 
68000 family of microprocessors, such as the 68030 or 68040 or PowerPC such as the 
601 or 604 manufactured by Motorola, Inc. of Schaumburg, Illinois. 
25 Note that the following discussion of the user interface display methods and 

apparatus of the preferred embodiment discussed herein will refer specifically to a 
series of routines which are compiled, linked, converted to object code in computer 
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system 200, and loaded into main memory 204 for execution during system run- 
time. It can be appreciated by one skilled in the art, however, that the method and 
computer systems according to the present invention may be implemented in 
special purpose hardware devices, such as discrete logic devices, large scale 
5 integrated circuits (LSTs), application-specific integrated circuits (ASIC's), or other 
specialized hardware. It can thus be appreciated by one skilled in the art that the 
description herein has equal application to other computer systems having similar 
functions. 

Figure 3 shows a block diagram representing a computer system having an 
10 : : electronic mail system according to the present invention and implementing the 

□ process according to the present invention. The computer system according to the 

fti present invention includes an installer application program 28, a relay application 
program 18, a select application program 26, and a remover application program 30. 

if- Any and/or all of these functional blocks or data may be stored in main memory 204 
(shown in dotted lines) at any given time according to the need to have the 

^ particular block reside in the main memory operated upon (e.g. read or executed). 
The installer application program 28 can change the creator type of all local copies of 
the dedicated mail processing application (e.g. block 16) in the local system from its 
original creator type r aaaa' to another creator type 'cccc.' A dedicated processing 
20 application 16 or a local copy thereof is an application which can process an object 
generated by the dedicated creator application program 10. That is, the dedicated 
creator application 16 or the local copy thereof has the same creator type as dedicated 
creator application program 10. Relay application 18, which assumes the creator type 
'aaaa' of the dedicated processing application 10, launches the preferred mail 

25 processing application 20 when a certain type or types of event/ events is/ are 

received. Relay application 18 then forwards the event to the preferred processing 
application 20. Selection application 26 allows the user to select the preferred 
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processing application 20 via a graphic user interface (GUI) (not shown). While the 
selection of the preferred processing application 20, in a preferred implementation, 
is done with a GUI, text interfaces can be used as well. The remover application 30 
allows the user to delete the relay application 18 and the selection application 26 
5 from the system. This application restores back to 'aaaa' the creator type of all local 
copies of the dedicated processing application 16, which have been assigned the 
alternate creator type 'cccc' during installation. 

As one can see from Figure 3, in operation, an object 12 having a first creator 
i- type 'aaaa' is processed by the operating system 14. This object may include a mail 
10 document transmitted by a first system 250 to the local system 200, or any other 
C object created by another dedicated creator application 10. If a user selects the object 
ffi 12 by means of the selection GUI, an event associated with the object 12, such as a 
G print document or open document, is generated. As the creator type of the relay 
ft; application 20 has been modified to 'aaaa', which is the creator type of the dedicated 
|;5 mail processing application 16, finder 15 causes this event to be received by the relay 
application 18. The relay application 18 then forwards the event associated with 
object 12 to a preferred destination application 20, instead of forwarding the event 
associated with the object to the dedicated mail processing application 16. 

Figure 4 is a block diagram illustrating installation of the relay application 22 
20 and of the selection application 26 in an embodiment of the present invention. 
Installer application 28 is an application program designed to prepare the user's 
system 200 for installation and to copy the files required to run the relay application 
22 and the selection application 26. The preparation of the user system 202 includes 
searching all non-volatile storage devices (e.g. 207) for all copies (e.g. 16) of the 
25 dedicated mail processing application and changing the creator type in the file 

systems. The files installed by this processor include the relay application 22 and the 
selection application 26. As explained above, installer 28 changes the creator type of 
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all local copies of the dedicated mail processing application 16 from 'aaaa' to 'cccc' 
In so doing, the computer system and the process of the present in/ention ensure 
that during system operation, the relay application program 22 will forward an 
event associated with object 12 to the preferred destination application 20 when 
5 configured by the user. As one can see, the relay application 22 assumes the creator 
type 'aaaa' of the dedicated processing application 16 in order to intercept events 
directed to the dedicated processing application program 16. 

The installation of the relay application is performed by an installer 
*K application 28 at the request of a user. A user can initiate the installation of the relay 
10 application by means of an installation dialog box 500 illustrated in Figure 5. The 
[:: explanatory dialog illustrated in Figure 5 is a preferred non-limiting 
Fr implementation for installing the relay application. A text implementation can be 
12 used as well. The dialog box 500 includes an "Install" button 502, a "Cancel" button 
f? ■ 504, the icon 506 representing a selected or de-selected preferred processing 
15 application and icon 508 representing a selected or de-selected relay application. If 
u the user selects the "Install" button 502, the installer application will be activated 
according to the process illustrated in conjunction with the flowchart diagram of 
Figure 6. 

The installation process 600 illustrated in Figure 6 starts at block 602 upon a 
20 user's activation of the "Install" button of the dialog box 500. At block 604, the 

installer will check the creator type of the dedicated mail processing application 16. 
This step is performed, assuming that the computer system according to the present 
invention can have more than one mail processing application and only one such 
application, at one time, is assigned as the dedicated mail processing application 16. 
25 In case that the computer system has only one dedicated mail processing application 
16, the step of checking the creator type of the dedicated mail processing application, 
performed at block 604, can be skipped and the installer can go to step 606. At block 
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606, the installer scans the user's local drives (e.g. 207) for all copies of the dedicated 
mail processing application 16. In this particular example, installer 28 scans the local 
drives for all instances of applications having the creator type 'aaaa/ Installer 28 
then determines, at decision block 608, if any of the applications in the user's local 
5 drives have the same creator type as the dedicated mail processing application 16. If 
the local drives coupled to the user's system 200 contain applications that have the 
same creator type as the dedicated mail processing application, then the installer 
changes the creator type of these applications to a second creator type 'cccc/ different 
^ from creator type 'aaaa,' at block 610. In an Apple® system, the installer also fixes 
10 the bundle resource for the dedicated mail processing application 16 so that its icon 
C matches its new creator type 'cccc.' A resource is defined as any data stored 
ft: according to a defined structure in a resource fork of a file. A bundle resource 
D associates all of the resources used by the Finder to an application. In particular, a 

bundle resource associates an application and its documents with their 
|S corresponding icons. 

The installer then places the relay application in condition for launching by 
placing the relay application in the Extension's Folder of the startup disk at block 
612. The Extensions Folder, located in the System Folder, holds code that is not part 
of the basic system software, but that provides system-level services, such as printer 
20 drivers and system extensions among other things. The items found in the 

Extensions Folder, including the relay application 18, are started up every time the 
Finder 15 starts up the system. 

Accordingly, in one embodiment of the present invention, relay application 
18 will be launched by the Finder 15 at system startup time. However, it is 
25 conceivable that users can set up their system such that the relay application 18 may 
be placed at another location where this application program can be launched 
conveniently at some predetermined time or when required. At block 614, installer 
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28 installs selection application program 26 by placing selection application program 
26 in the Mail and Catalogs folder ox the Apple Menu Items folder of the startup 
disk. The Mail and Catalogs folder, just like the Extensions folder, is a 
predetermining place in the system. Then, the explanatory dialog 500 illustrated in 
5 Figure 5 is dismissed and the user receives a message noting whether or not the 
installation was successful. 

Once relay application 18 and selection application 26 are installed, selection 
application 26 can be invoked at any time from the Mail and Catalogs folder, in case 
'■£} a user wishes to change preferred processing application 20. Selection application 
10 program 26 can present a movable modeless dialog box which provides for changing 
q a current processing application to a preferred processing application. 
:j; Figure 7 shows a flowchart diagram illustrating the operation of relay 

f application 18. Relay application 18 is launched at startup initialization, at block 702 
in Figure 7. While this application is launched at startup, it can be subsequently quit 
;15 and relaunched. At decision block 704, the relay application checks whether there 
are any high level events (e.g. "open document" or "print document"), associated 
with the received object, sent to relay application 18 by the Finder 15. If an event is 
received, then relay application 18 intercepts the event at block 706. The respective 
event is intercepted by relay application 18, because the relay application has the 
20 same creator type (e.g. 'aaaa') as the creator type of the dedicated mail processing 

application 16. As previously discussed, events associated with an object created by a 
creator processing application 10 are not intercepted by local copies of the dedicated 
mail processing application 16, because the installer has previously changed the 
creator type of all copies of the dedicated application to a second creator type, as 
25 shown in Figure 6 at block 610. Process 700 then goes to block 708 where it launches 
the preferred processing application 20 upon receipt of an open or print document 
event. Relay application 18 knows what is the selected preferred processing 
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application 20 by referring to a file called "preferences file" where aliases of the 
preferred processing applications and the signature of these applications are stored. 
Then, relay application 18 changes the target of the open or print document event to 
the preferred mail processing application 20. Finally, at block 710, the open 
5 document or print document event will be forwarded by relay application 18 to the 
preferred mail processing application 20. 

Figure 8 illustrates graphically a flowchart of the relay application process for 
Apple® brand Computer Systems. After startup initialization, at block 802, relay 
application 18 proceeds to install AppleEvent handlers at block 804. Then the relay 
10 application enters its event loop at block 806. At this block, as is typical in event 
I" handlers, the next event from the event queue is retrieved. The event loop of the 
g: relay application filters only on high level events such as "open" document at 

decision block 808 and "print" document events at decision block 810. If an open 
ifi document event or print document event has been received, then the open 
15 document event handler 812 or the print document event handler 814 passes 

control to the ForwardAppleEvent function at block 816. The ForwardAppleEvent 
function resolves the alias or pointer to the preferred mail processing application 20, 
stored in the "preference file" which contains an alias to the preferred mail 
processing application 20 and its signature (creator ID). The ForwardAppleEvent 
20 function changes the target address of the AppleEvent received to the preferred mail 
processing application and then resends the event At block 818, control is 
transferred to the preferred mail processing application 20 wherein the event 
forwarded to it will be serviced. 

Figure 9 illustrates a block diagram of the computer system according to the 
25 present invention with Remover application 30 activated. Remover application 30 
is a standard application which acts upon the relay application 18 and the selection 
application 26 and de-installs or deactivates these applications, essentially 
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performing the reverse of the operations performed during installation. Also, 
Remover application 30 acts upon the copies of the dedicated mail processing 
application 16, having the creator type 'cccc/ and replaces this creator type with the 
original creator type 'aaaa.' 
5 Figure 10 shows a flowchart diagram illustrating the process of removing an 

application according to the present invention. As one can see, part of the removal 
process includes searching local drives, at block 1004, for copies of dedicated mail 
processing application 16 having creator type 'cccc.' At block 1006, remover 
I" application 30 determines whether any of the applications of the local drives have 
10 'cccc' for creator type, and at block 1008, remover application 30 changes the creator 
t typ e of all the applications having the second type 'cccc' to the creator type 'aaaa/ 
M which in this case, corresponds to the original creator type of the dedicated mail 
r. processing application 16. The remover then fixes the dedicated mail processing 
application's bundle resource so that its icon matches its new creator type 'aaaa.' 
1$ The Remover then deletes the relay application and the selection application. 

Figure 11 shows a memory device storing the application programs according 
to the present invention, together with the operating system. As one can see, a 
memory, 1100 stores in a first region 1102 a relay application 22. The relay 
application program has a first program portion 1101 directed to intercepting the 
20 event associated with an objected generated by the dedicated creator application 

program. The relay application program further has a second program portion 1103 
directed to forward the intercepted event to the preferred processing application 
program. Memory 1100 further includes, in a second region 1104, a selection 
application program 26 for selecting the preferred processing application program. 
25 The memory 1100 further stores in a third region 1106 an installation application 
program for installing the relay application program and the selection application 
program. Furthermore, the memory 1100 stores in a fourth region 1108 a remover 
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application programmed for de-installing the relay and selection application 
programs. In addition, the memory 1100 stores in a fifth region 1110 an operating 
system program. The operating system program performs the customary functions 
that operating systems perform in computer systems. In addition, the operating 
system shown in Figure 11 is responsible for activating or launching the relay 
application program stored in the first region. 

As explained above, the present invention can be implemented in special 
purpose hardware devices, such as discrete logic devices, large scale integrated 
circuits (LSI's), and application-specific integrated circuits (ASIC's). In such a 
computer system, the applications of the present invention could be implemented 
in hardware modules coupled to each other as shown in Figures 3, 4, and 9. 

In the foregoing specification, the invention has been described with 
reference to specific embodiments thereof. It will however be evident that various 
modifications and changes can be made thereto without departing from the broader 
spirit and scope of the invention as set forth in the appended claims. The 
specification and drawings are, accordingly, to be regarded in an illustrative rather 
than a restrictive sense. Therefore, the scope of the invention should be limited 
only by the appended claims. 
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CLAIMS 



What is claimed is: 



1 1. A computer-related method for processing, with a preferred processing 

2 application program having a preferred identifier, an event associated with an object 

3 generated by a dedicated creator application program, said dedicated creator 

4 application having a dedicated identifier, said method comprising the following 
,[f5 steps: 

-,6 a. receiving the event; 

r7 b. intercepting the event with a relay application program; and 

[j8 c. forwarding, with said relay application program, said intercepted event 

'IS to said preferred processing application program. 

Ji 2. The computer-related method of claim 1 wherein said step of 

^2 forwarding said intercepted event includes the steps of 

3 identifying the preferred processing application; 

4 launching the preferred processing application; 

5 sending the event to the preferred processing application program. 

1 3. The computer-related method of claim 2 further including the 

2 preliminary steps of 

3 installing said relay application program; 

4 associating with said relay application said dedicated identifier; 

5 installing a selection application program; and 

6 selecting, with said selection application program, the preferred processing 

7 application program, 
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8 wherein the preliminary steps are performed prior to steps a through c. 

1 4. The computer-related method of claim 3 wherein said dedicated 

2 identifier corresponds to a first creator type of the dedicated processing application 

3 program. 

1 5. The computer-related method of claim 4 wherein said preferred 

; 2 identifier corresponds to a second creator type of the preferred processing application 

^;3 program. 

Cl 6. The computer-related method of claim 5 wherein said relay application 

K ; 2 is installed according to the following steps, 
~3 receiving an install command; 

[L4 scanning local drives for all applications having said first creator type; 

F5 changing the creator type of all applications having said first creator type to a 

6 third creator type; 

7 placing said relay application in condition for launching at a predetermined 

8 time; and 

9 providing user accessibility to said selection application program via a 
10 selection graphic user interface (GUI). 

1 7. The computer-related method of claim 6 wherein said predetermined 

2 time is the system initialization time. 

1 8. The computer-related method of claim 6 wherein said step of placing 

2 said relay application in condition for launching is implemented by placing said 

3 relay applications into a first location of a memory. 
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1 9. The computer-related method of claim 6 wherein said step of 

2 providing user accessibility to said selection application via said GUI is 

3 implemented by placing said selection application into a second location of said 

4 memory. 

1 10. The computer-related method of claim 3 wherein said relay application 

2 is removed according to the following steps, 
.3 receiving a remove command; 

&4 scanning local drives for all applications having said second creator type; 

-5 changing the creator type of all applications having said second creator type to 

f:6 said first creator type; and 

£7 removing said relay application program from said first location of said 

;8 memory. 

-1 11. A computer system for processing, with a preferred processing module 



~~2 having a preferred identifier, events associated with an object generated by a 

3 dedicated creator module having a dedicated identifier, said events being directed to 

4 a dedicated processing module with a dedicated identifier, said computer system 

5 including a processor, a memory coupled to said processor, an interactive 

6 input/output system coupled to said processor, a display coupled to said processor, 

7 said computer system further comprising: 

8 module for relaying said event, associated with an object generated by said 

9 dedicated processing module, to said preferred processing module, said module for 

10 relaying being coupled to said processor; 

11 module for selecting said preferred processing module, said module for 

12 selecting being coupled, at an input thereof to said preferred processing module, and 

13 at an output thereof to said module for relaying; 
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14 module for installing said module for relaying and said module for selecting, 

15 said module for installing being coupled, at an output thereof to said module for 

16 relaying and to said module for selecting; and 

17 module for decoupling said module for relaying and said module for 

18 selecting, 

19 wherein said module for relaying is adapted to intercept an event associated 

20 with an object generated by said dedicated creator module, said module for relaying 

21 being also adapted to forward said intercepted event to said preferred processing 
§2 module. 

El 12. The computer system of claim 11 wherein said module for relaying has 

1:2 an input for receiving a preferred module identification signal from said module for 

p3 selecting. 

pi 13. The computer system of claim 12 wherein said module for relaying 

"2 has an output for activating the preferred module. 

1 14. The computer system of claim 13 wherein said module for relaying has 

2 a relay processing logic for changing the dedicated identifier of the event with the 

3 preferred identifier, said relay processing logic being adapted to send, via the output 

4 of the module for relaying, the event with a preferred identifier to the preferred 

5 processing module. 



1 15. A computer system for processing, with a preferred processing 

2 application program having a preferred identifier, events associated with objects 

3 generated by a dedicated creator application program, said events being directed to a 

4 dedicated processing application destination with a dedicated identifier, said 
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5 dedicated creator application program having a dedicated identifier, said computer 

6 system including a processor, a computer-readable storage medium coupled to said 

7 processor, an interactive input/output system coupled to said processor, a display 

8 coupled to said processor, said computer-readable storage medium comprising: 

9 a first region storing a relay application program for relaying an event 

10 associated with an object generated by the dedicated creator application program to 

11 said preferred processing application program; 

12 a second region storing a selection application program for selecting said 
43 preferred processing application program; 

14 a third region storing an installation program for installing said relay 

C$5 application program and said selection application program; and 
CI6 a fourth region storing a remover application program for de-installing said 

Q7 relay and selection application programs; 

f§8 wherein said relay application program has a first program portion directed to 



ft9 intercept said event associated with an object generated by said dedicated creator 

~50 application program, said relay application program further has a second program 

21 portion directed to forward said intercepted event to said preferred processing 

22 application program. 

1 16. The computer system of claim 15 wherein said computer-readable 

2 storage medium further includes a fifth region for storing an operating system 

3 program, said operating system program including a program portion for activating 

4 said relay application program stored in said first region. 

1 17. A computer system for processing, with a preferred processing 

2 application program having a preferred identifier, events associated with objects 

3 generated by a dedicated creator application program, said dedicated creator 
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4 application program having a dedicated identifier, said events having a dedicated 

5 processing application destination with a dedicated identifier, said computer system 

6 including a processor, a computer-readable storage medium coupled to said 

7 processor, an interactive input/output system coupled to said processor, a display 

8 coupled to said processor, said computer-readable storage medium comprising: 

9 means for relaying said event, associated with an object generated by said 

10 dedicated processing application, to said preferred processing application, said means 

11 for relaying being coupled to said processor; 

32 means for selecting said preferred processing application program, said means 

|3 for relaying being coupled to said processor; 

1 16 means for installing in said computer system said means for relaying and said 
f5 means for selecting, said means for relaying being coupled to said processor; 

SS means for de-installing said means for relaying and said means for selecting, 

117 said means for relaying being coupled to said processor; 

C18 wherein said means for relaying is adapted to intercept an event associated 

19 with an object generated by said dedicated processing application program, said 

20 means for relaying being also adapted to forward said event to said preferred 

21 processing application program. 
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ABSTRACT 



A method and apparatus for processing with a preferred processing 
application having a preferred identifier, an event associated with an object created 
by a dedicated creator application is provided. The method includes the steps of 
receiving the event, intercepting the event with a relay application program, and 
forwarding, with the relay application program, the intercepted event to the 
preferred processing application program. 
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Click "Install" to install the software. Once installed, you may use 
"Select AppleMail Reader" from the "Mail and Catalogs" menu to 
change your preferred AppleMail reader at any time. 



Cancel 





Install 

S 



7 



504 



502 



FIG. 5 



START 



Jo5 02 



CHECK CREATOR TYPE OF DEDICATED 
MAIL PROCESSING APPLICATION 



SCAN CREATOR TYPE OF APPLICATIONS IN 
THE USER'S LOCAL DRIVES 



CHANGE THE CREATOR TYPE OF THESE 
APPLICATIONS TO CREATOR DIFFERENT 
THAN THE ONE OF THE DEDICATED 
APPLICATION 



PLACE RELAY APPLICATION IN CONDITION 
FOR LAUNCHING 



r\5 04 



^606 




n3 12 



INSTALL SELECTION APPLICATION 



n5 14 



END 



FIG. 6 




LAUNCH PREFERRED 
PROCESSING APPLICATION 



I 



FORWARD EVENT TO 
PREFERRED PROCESSING 
APPLICATION 



710 



END 



FIG. 7 



START 



^802 



OPEN HANDLER 



812 



PRINT HANDLER 



A 7 

814 



ForwardAppleEvent 



816 



INSTALL AppleEvent 
HANDLERS 



WAIT NEXT EVENT 



804 



ri3 



806 




PREFERRED APPLICATION ^] 818 
PROCESSES EVENT ^ 



FIG. 8 



o 

C\J 



o 

C\l 




CD 



03 
03 



o 
o 



START 



I 



ji7 2 



CHECK CREATOR TYPE OF ALL 
APPLICATIONS IN THE LOCAL DRIVES 



DO ANY OF THESE 
APPLICATIONS HAVE A 
SECOND CREATOR TYPE 
('cccc')? 



1006 



1004 



NO 



YES 



CHANGE CREATOR TYPE OF ALL 
APPLICATIONS HAVING A SECOND 
CREATOR TYPE TO A FIRST CREATOR 
TYPE 



1008 



END 



FIG. 10 



RELAY APPLICATION 



INTERCEPT 



FORWARD 



22 



SELECTION 
APPLICATION 
26 



INSTALLER 
APPLICATION 
28 



REMOVER 
APPLICATION 
30 



OPERATING 
SYSTEM 
14 



FIG. 11 



Attorney's Docket No.: 04860. P1738 Patent 
DECLARATION AND POWER OF ATTORNEY FOR PATENT APPLICATION 



As a beiow named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below, next to my name. 

I believe I am the original, first, and sole inventor (if only one name is listed beiow) or an 
original, first, and joint inventor (if plural names are listed beiow) of the subject matter 
which is claimed and for which a patent is sought on the invention entitled 

METHOD AND APPARATUS FOR RELAYING EVENTS INTENDED FOR A 
FIRST APPLICATION PROGRAM TO A SECOND APPLICATION PROGRAM 

the specification of which 

X is attached hereto. 

was filed on as 

Application Serial No. . 

and was amended on . 

(if applicable) 

I hereby state that I have reviewed and understand the contents of the above-identified 
specification, including the claim(s), as amended by any amendment referred to above. I do not 
know and do not believe that the claimed invention was ever known or used in the United States 
of America before my invention thereof, or patented or described in any printed publication in 
any country before my invention thereof or more than one year prior to this application, that 
the same was not in public use or on sale in the United States of America more than one year 
prior to this application, and that the invention has not been patented or made the subject of an 
inventor's certificate issued before the date of this application in any country foreign to the 
United States of America on an application fiied by me or my legal representatives or assigns 
more than twelve months (for a utility patent application) or six months (for a design patent 
application) prior to this application. 

! scknovviedge the duty to disclose aii information known to me to be material to patentability as 
defined in Title 37, Code of Federal Regulations, Section 1.56. 

I hereby claim foreign priority benefits under Title 35, United States Code, Section 119, of any 
foreign application(s) for patent or inventor's certificate listed below and have also identified 
below any foreign application for patent or inventor's certificate having a filing date before that 
of the application on which priority is claimed: 

Priority 

Prior Foreign AppMcation(s) Claime d 



(Number) (Country) (Day/Month/Year Filed) Yes No 



(Number) (Country) (Day/Month/Year Filed) Yes No 

I hereby claim the benefit under Title 35, United States Code, Section 120 of any United States 
application(s) listed beiow and, insofar as the subject matter of each of the claims of this 
application is not disclosed in the prior United States application in the manner provided by the 
first paragraph of Title 35, United Statec Code, Section 112, I acknowledge the duty to disclose 
all information known to me to be material to patentability as defined in I itle 37, Code of 
Federal Regulations, Section 1.56 which became available between the filing date of the prior 
application and the national or PCT international^ filing date of this application: 



(Application Serial No.) Filing Date (Status — patented, y 

pending, abandoned) 



(Application Serial No.) Filing Date (Status patented, 

pending, abandoned) 



I hereby appoint Keith G. Askoff, Reg. No. 33,828; Aloysius T. C. AuYeung, Reg. No. 35,432; 
Bradley J. Bereznak, Reg. No. 33,474; Michael A. Bernadicou, Reg. No. 35,934; Roger W. 
Blakely, Jr., Reg. No. 25,831; Timothy R. Croll, Reg. No. 36,771; William Donald Davis, Reg. 
No. 38,428; Daniel M. De Voc, Reg. 37,813; Scot A. Griffin, Reg. No. 38,167; Stephen D. 
Gross, Reg. No. 31,020; David R. Halvorson, Reg. No. 33,395; Michael D. Hartogs, Reg. No. 
36,547; Brian Don Hickman, Reg. No. 35,894; George W Hoover If, Reg. No. 32,992; Paul H. 
Horstmann, Reg. No. 36,167; Eric S. Hyrnan, Reg. No. 30,139; Dag H. Johansen, Reg No. 
36,172; Stephen L. King, Reg, No. 19,180; Joseph T. Lin, Reg. No. 38,225; Michael J. Mailte, 
Reg. No. 36,591; James D. McFarland, Reg. No. 32,544; Anthony C. Murabito, Reg. No. 35,295; 
Kimberiey G. Nobles, Reg. No. 38,255; Ronald W. Reagin, Reg. No. 20,340; Kent R. Richardson, 
Reg. No. P39,443; James H. Salter, Reg. No. 35,668; William W. Schaal, Reg. No. P39,018; 
James C. Scheiier, Reg. No. ;11,195; Edward W. Scott, IV, Reg. No. 36,000; Maria McCormack 
Sobrino, Reg. No. 31,639; Stanley W. Sokoloff, Reg. No. 25,128; Allan T. Sponseller, Reg. No. 
38,318; John C. Startler, Reg. No. 36,285; Edwin H. Taylor, Reg. No. 25,129; Lester J. 
Vincent, Reg. No. 31,460; Ben J. Yorks, Reg. No. 33,609; and Norman Zafman, Reg. No. 
26,250; Mark Aaker, Reg. No. 32,667; Paul D. Carmichael, Reg. No. 18,679; Vernon Randall 
Gard, Reg. No. 33,886; Richard C. Liu, Reg. No. 34,377; Robert T. Martin, Reg. No. 32,426; 
Heiene S. Plotka, Reg. No. 35,981; and Nancy R. Simon, Reg. No. 36,930; my attorneys; and 
Gary B. Goates, Reg. No. 35,159; Soyeon P. Laub, Reg. No. P39,266; Thomas X. Li, Reg. No. 
37,079; and Edwin A. Sloane, Reg. No. 34,728; my patent agents; of BLAKELY, SOKOLOFF, 
TAYLOR & ZAFMAN, with offices located at 12400 Wilshire Boulevard, 7th Floor, Los Angeles, 
California 90025, telephone (310) 207-3800, with full power of substitution and 
revocation, to prosecute this application and to transact all business in the Patent and 
Trademark Office connected herewith. 

I hereby declare that all statements made herein of my own knowledge are true and that ail 
statements made on information and belief are believed to be true; and further that these 
statements were made with the knowledge that willful false statements and the like so made are 
punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United 
States Code and that such willful false statements may jeopardize the validity of the application 
or any patent issued thereon. 



Full Name of Sole/First Inventor Hossein David Akhond „ 



Inventor's Signature 



Residence Santa Clara. California Citizenship USA 



(City, State) (Country) 



Post Office Address 3087 Pruneridae Avenue 

Santa Clara. California 95051 



Full Name of Second/Joint Inventor Gregory Georae Scown 



inventor's Signature ^^^y 
Residence Sunnyvale. California Citizenship USA 



(City, State) (Country) 



Post Office Address 1905 B lackberry Terrace 



Sunnyvale. Californ ia 94087 



Full Name of Third/Joint Inventor Johnathon Pau l Kaminar 



Date 3— Q> 



Inventor's Signature 

Residence Santa Clara. California Citizenship — USA 



(City, State) (Country) 



Post Office Address 3380 Tracv Drive 



Santa Clara. California 95051 



